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DETAILED ACTION 

1 . A request for continued examination under 37 CFR 1.114, including the fee set 
forth in 37 CFR 1.17(e), was filed in this application after final rejection. Since this 
application is eligible for continued examination under 37 CFR 1.1 14, and the fee set 
forth in 37 CFR 1.17(e) has been timely paid, the finality of the previous Office action 
has been withdrawn pursuant to 37 CFR 1.114. Applicant's submission filed on 8/17/05 
has been entered. 

Claim Rejections - 35 USC § 102 

2. The following is a quotation of the appropriate paragraphs of 35 U.S.C. 102 that 
form the basis for the rejections under this section made in this Office action: 

A person shall be entitled to a patent unless - 

(b) the invention was patented or described in a printed publication in this or a foreign country or in public 
use or on sale in this country, more than one year prior to the date of application for patent in the United 
States. 

3. Claims 1-20 are rejected under 35 U.S.C. 102(b) as being anticipated by Meier, 
U.S. Patent No. 5,802,371. 

As per claim 1 , Meier discloses a computer system for generating metadata 
for use during stack unwinding (col. 2:27-47, "When displaying the caller stack of a 
distributed client/server program that uses Remote Procedure Calls (RPC), the user is 
provided the capability of viewing the RPC calls in the same manner as normal 
procedure calls. For example, when a breakpoint is encountered in an RPC server 
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program while using a debugger for distributed programs, the call stacks for the client 
and server program (comprise the modified program) are appended together into a 
single distributed call stack... The distributed call stack may span many programs, 
threads of execution, and computing machines... The distributed call stack may be used 
to select a routine from the call stack when setting a context for a tool that displays 
program state information (i.e. metadata for use during stack unwinding). For example, 
when the user selects a particular routine from the distributed call stack, the source 
listing, variables that are currently in scope, and thread executing the routine may be 
shown (i.e. metadata for the modified program, for use during stack unwinding is 
generated)"), comprising: 

- a plurality of procedures wherein each procedure comprises a sequence 
of binary instructions (col. 2:34, "client ... program (i.e. procedures comprising a 
sequence of binary instructions)"), 

- a first plurality of blocks of metadata having a first order of blocks, 
wherein each block of metadata is associated with a corresponding procedure in 
the plurality of procedures (col. 2:43-46, "when the user selects a particular routine 
(i.e. procedure) from the distributed call stack, the source listing, variables that are 
currently in scope, and thread executing the routine may be shown (i.e. a first plurality of 
metadata associated with the corresponding procedure"), 

- an unwind rewriter programmed to reorder the first plurality of blocks of 
metadata to generate a second plurality of blocks of metadata having a second 
order, wherein the first plurality of blocks are reordered in response to a 
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modification of the sequence of binary instructions within a procedure, (col. 4:59- 
62, "To verify the proper operation of such a distributed set of client/server programs, 
the user may wish to debug the distributed set of client/server programs as if they were 
one single program", in this case, the unwind rewriter takes a first plurality of blocks of 
metadata from each of the distributed client/server programs and merges them to form 
reordered blocks of metadata), such that the second plurality of blocks of metadata 
accurately represents the modified sequence of binary instructions (col. 2:43-46, 
"when the user selects a particular routine (i.e. modified sequence of binary instructions, 
consisting of interlaced/nested instructions called by the client and server machines) 
from the distributed call stack, the source listing, variables that are currently in scope, 
and thread executing the routine may be shown (i.e. a second plurality of metadata 
representing the modified sequence of binary instructions"). 

As per claim 2, the rejection of claim 1 is incorporated and further, Meier 
discloses that each block of metadata in the plurality of blocks of metadata 
includes at least one unwind table and at least one unwind information block (col. 
5:2-3, "The present invention also provides the capability of walking up this distributed 
call stack", and to walk a call stack, one needs to identify the base/starting basic block 
of the stack and the current/end basic block stack pointer. The instant application 
stores this information in the unwind table. Additionally, walking a call stack involves an 
ordered set of actions over a contiguous region of code (i.e. the information pointed 
to/contained by the unwind information block)). 
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As per claim 3, the rejection of claim 2 is incorporated and further, Meier 
discloses that the at least one unwind information block includes a region header 
describing a region of zero length (col. 5:2-3, "The present invention also provides 
the capability of walking up this distributed call stack", and to walk a call stack, one 
needs to identify the base/region header of the stack and the current/end basic block 
stack pointer."). 

As per claims 4 & 5, this is a computer implemented method version of the 
claimed system discussed above, in claims 1 & 2, wherein all claimed limitations have 
also been addressed and/or cited as set forth above. For example, see Meier's method 
of walking-up a call stack for a client/server program (col. 2:27-3:10). And, Meier 
discloses "storing (i.e. writing) the call relation (i.e. unwind data) between two parallel 
processing applications", at col. 1:49-51. 

As per claim 6, the rejection of claim 5 is incorporated and further, Meier 
discloses that parsing the original unwind data comprises identifying a start basic 
block and an end basic block of a region associated with the modified binary 
procedure (col. 2:50, "walking up a call stack", and to walk a stack, one needs to 
identify the base/starting basic block of the stack and the current/end basic block stack 
pointer). 



Application/Control Number: 09/997,056 Page 6 

Art Unit: 2192 

As per claim 7, the rejection of claim 6 is incorporated and further, Meier 
discloses that identifying the end basic block of the region further comprises 
splitting a single basic block into two basic blocks, such that a first basic block 
ends on a last instruction of the region (col. 2:50, "walking up a call stack", and when 
the current stack pointer resides in the middle of a basic block, that location is identified 
as the end of the call stack, for the purposes of a stack walk). 

As per claim 8, the rejection of claim 6 is incorporated and further, Meier 
discloses that parsing the original unwind data further comprises identifying an 
unwind information block associated with a basic block in the original order of 
the basic blocks that includes a when action description record and establishing 
a link between the when action description record and the corresponding 
instruction in the basic block (col. 2:50, "walking up a call stack", and walking the 
stack involves determining the information stored by the when action description 
record). 

As per claim 9, the rejection of claim is incorporated and further, Meier discloses 
that regenerating new unwind data comprises regenerating new unwind tables 
and new unwind descriptor records (col. 5:2-3, "The present invention also provides 
the capability of walking up this distributed call stack", and to walk a call stack, one 
needs to identify the base/starting basic block of the stack and the current/end basic 
block stack pointer. The instant application stores this information in the unwind table. 
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Additionally, walking a call stack involves an ordered set of actions over a contiguous 
region of code (i.e. the information pointed to/contained by the unwind information 
block)). 

As per claim 10, the rejection of claim is incorporated and further, Meier 
discloses that regenerating the new unwind descriptor records further comprises 
determining if basic blocks identified in a single unwind table associated with the 
original order of basic blocks are associated with more than one unwind table 
associated with the current order of basic blocks, and if so, creating a new region 
header describing a region of zero length (col. 5:2-3, "The present invention also 
provides the capability of walking up this distributed call stack", and to walk a call stack, 
one needs to identify the base/starting basic block of the stack and the current/end 
basic block stack pointer. The instant application stores this information in the unwind 
table. Additionally, walking a call stack involves an ordered set of actions over a 
contiguous region of code (i.e. the information pointed to/contained by the unwind 
information block)). 

As per claims 11-14, these are a computer implemented method version of the 
claimed system discussed above, in claims 6-10 , wherein all claimed limitations have 
also been addressed and/or cited as set forth above. For example, see Meier's method 
of walking-up a call stack for a client/server program, at col. 2:27-3:10, col. 10:8-26, "A 
method for debugging a distributed computer program comprising a client program 
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executing on a first portion of a distributed data processing system and a server 
program executing on a second portion of the distributed data processing system, said 
method comprising the steps of: 

(a) determining a first call stack (i.e. a first group of unwind data) on the first portion of 
the distributed data processing system of the client program; 

(b) determining a second call stack (i.e. additional data from the first group of unwind 
data ) on the second portion of the distributed data processing system of the server 
program by evaluating remote procedure call (RPC) run-time data structures; 

(c) appending the first call stack and second call stack together on the first portion of 
the distributed data processing system to form a single distributed call stack (i.e. the 
second group of unwind data composed of the reordering of the first group of unwind 
data)" and col. 4:59-62, "To verify the proper operation of such a distributed set of 
client/server programs, the user may wish to debug the distributed set of client/server 
programs as if they were one single program" (in this case, the unwind data accurately 
represents the modification in ordering of the distributed processes). 

As per claims 15-20 these are computer readable medium versions of the 
claimed system discussed above, in claims 1-3 and 6, wherein all claimed limitations 
have also been addressed and/or cited as set forth above. For example, see Meier's 
method of walking-up a call stack for a client/server program (col. 2:27-3:10). 



Response to Arguments 
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4. Applicants arguments have been considered but they are not persuasive. 
In the remarks, the applicant has argued substantially that: 

1) The cited art does not disclose the newly added features of presently amended 
claims 1, 4, 11, 15, 19 and 20, at p. 7:4-10:2. 

Examiner's response: 

1 ) In response to applicant's argument that the references fail to show the new 
limitations of the presently amended claims, it is noted that the newly added limitations 
upon which applicant relies are fully addressed at Meier, col. 4:59-62 and 10:8-26 and 
in the above art rejection. 

In the remarks, the applicant has argued substantially that: 

2) Meier doesn't disclose a second unwind table, at p. 9:23. 

Examiner's response: 

2) The examiner disagrees with applicant's characterization of the applied art. 
Meier discloses multiple unwind tables, as his invention deals with multiple distributed 
client and server applications, each with their own unwind information, see Meier 10:8- 
26 and the above art rejection. 

In the remarks, the applicant has argued substantially that: 
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3) Meier doesn't disclose that the unwind data accurately represents the binary 
modification to the procedure, at p. 9:32. 

Examiner's response: 

3) The examiner disagrees with applicant's characterization of the applied art. 
Meier does disclose that the unwind data accurately represents the binary modification 
to the procedure, at col. 4:59-62, "To verify the proper operation of such a distributed 
set of client/server programs, the user may wish to debug the distributed set of 
client/server programs as if they were one single program" (in this case, the unwind 
data accurately represents the modification in ordering of the distributed processes), as 
addressed in the art rejection, above. 

Conclusion 

5. Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Andre R. Fowlkes whose telephone number is (571) 
272-3697. The examiner can normally be reached on Monday - Friday, 8:00am- 
4:30pm. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Tuan Q. Dam can be reached on (571)272-3695. The fax phone number for 
the organization where this application or proceeding is assigned is 571-273-8300. 
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Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). 
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